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.0 
إلى والدي العزيز الذي له المقام الأول لتشجيعي 


HÎ‏ ك 
دي هذا الكتاب الى أصدقائي وزملائي لمن يريد تعلم هذا الكتاه 


i 2 1 
۳ 0 

إهدائي الخاص للاستاد: 
الثرالصرمي الذي حفزنا لحب هذه المادة واللغة خاس 
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الصكعدصة 
العمد لله رب العالمين والصلاة والسلام على انقرف الانرياء والعمرساين 


محمد ين عيدا لله الصادق الامين اع بعه: 

إن النشاط اليومي للمؤسسات في كافة مجالات العمل يعتمد اعتماد كبير على البيانات وتحرص 
المؤسسات على امتلاك قدر من المعلومات حيث بدا العمل في مختلف المؤسسات من خلال العمل 
اليدوي والتي كان لها كثير من العيوب مثل الجهد الزائد والبطء في تسجيل مئات أو الالآف البيانات 
اليدوية حيث قلت الدقة وصحة البيانات إلى درجة كبيرة بسبب التعب والخطأ البشري حيث كانت 
البيانات تتعرض للضياع والسرقة ولا يوجد نسخ أخرى لها. 

ومن خلال ذلك عمل العلماء للتوصل إلى طرق جديدة لتعامل مع البيانات وخاصة مع تزايد كمية 
كبيرة من البيانات وظهور الحواسيب وانتشارها وتبسيط اللغات البرمجية حيث ظهرت الملفات 
المعدة عن طريق الحاسوب والتي مثلت تقدم هائل في بيئة الأعمال . 


صقدصة اوراکل : 


أن الأوراكل لا تعتبر لغة برمجة وإنما هي لغة قواعد البيانات مبرمجة لقواعد البيانات فيجب 
علينا أن نعرف هذا الفرق الأساسي بين لغة قواعد البيانات الأوراكل وبين لغات البرمجة 


الأخرى 
فهي شبيهة إلىssصAcc Microsoft‏ وأقرب Microsoft SQL Server Ji!‏ 
ممیزات الأوراكل. 


-١‏ إنها قاعدة بيانات قوية وآمنة ؛تتمتع بأمان عالي جداً»وهو سبب أساسي لانتشارها الهائل 
رغم التكلفة العالية لها. 

۲- أنها تعتبر قواعد بيانات ضخمة. 

۳- يوجد لديها أدوات تساعدها لتعامل معها وإظهارها في أشكال متعددة»بما يسمى تطبيقات 
ُوراکل أي: !ل۴۸ DE۷٤0 P٤‏ ۔حیث تمكنك من إدخال البیانات واستخراجھا عن طریق 
نماذج وتقارير ورسوم بيانية »لكن لا يمكنها التعامل مع قاعدة بيانات غير أوراكل. 
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قواعد الalil Databases‏ . 
هي عبارة عن تجميع لكمية كبيرة من البيانات والمعلومات وعرضها بطريقة أوأكثر من طريقة 
ليسهل الاستفادة منها. 
بمعنى آخر: هي عبارة عن مجموعة من البيانات المترابطة مع بعضها البعض بعلاقات منطقية 


والمخزنة في ملفات بطريقة منظمة تمنع التكرار الغير مبرر (قواعد بيانات أ/أروى الإرياني) 


سيكون الجرء الأول عبارة عن 


SQL أواھر‎ 
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ما هى (Structured Query Language) : SQL‏ 
هي لغة قياسية من لغات الحاسب لدخول ومعالجة قواعد البيانات » وهي لغة بناء الاستعلامات 
الهيكلية . 


و کا ھا : 


١-لغة‏ قياسية من لغات الحاسب الخاصة بمعهد American )ANS|‏ 
(National Standards Institute‏ 
۲- تمكنك من الدخول لقواعد البيانات 
۳- تمكنك من استخراج البيانات من القاعدة 
؛- تمكنك من إضافة بيانات إلى قاعدة البيانات 
٥-تمكنك‏ من الحذف والتعديل على البيانات المسجلة في القاعدة 
ملاحظة. 
S۵)‏ : هي لغة سهلة التعلم والفهم لمن أراد التعلم 
تنقسم لغة 5Q1‏ إلى الأقسام التالية: 
-١‏ القسم المسئول عن معالجة البيانات 
SQL Data Manipulation Language (DML)‏ 
* أوامر )DML)‏ 


8 اcعاSe‏ : استخراج البيانات من قاعدة البيانا 
in0 8‏ nseriا:‏ إضافة بیانات جدیدة 

8 eاaلdمل:‏ التعديل على البيانات 

8 مetاDe‏ : حذف البيانات من القاعدة 
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-١‏ القسم المسئول عن تعريف البيانات 
SQL Definition Language (DDL)‏ 


* أوامر ( 01 0): 

Create Database -‏ : إنشاء قاعدة بيانات جديدة 

Create Table -‏ : إنشاء جدول داخل قاعدة البيانات 
Alter Table -‏ : للتعديل على الجدول 

:Drop Table -‏ حذف الجدول من قاعدة البيانات 

Create Index -‏ : إنشاء فهرس أو مفتاح للبحث 

Drop Index -‏ : حذف الفهرس 


۳-القسم المسئول عن التحكم بالبيانات 
Data Control language(DCL)‏ 
أوامر 0٤1‏ 
- أاnمaا G‏ لمر أعطاء الصلاحيات (منح الصلاحية) 
Revoke -‏ أمر إلغاء الصلاحيات(منع الصلاحية) 


Sal*plus 


یوجد في بیحة (sں‌ا۴*-5۵1)‏ مستخدمین افتراضیین هما 
8 mءاءرء‏ وكلمة المرور : 96۲ة٣ه"‏ بغض النظر في حالة التحميل فيما 
اذا تم تغيير كلمة المرور فإنه يكتب كلمة المرور الجديدة. 
Scott 8‏ وکلمة المرور : ٣6وا‏ 
Sys 8‏ وکلم lالaرaر Change_on_install:‏ 
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يفيه إنشاء مستخدم جديد 


كيفية إنشاء مستخدم جديد في بيئة ( وuام‏ * اهء) هي كالتالي: 
الصيغة العامة: 
كلمة المرور اسم المستخدم 


SQL> create user [user name] identified [password]; 


8 لا يسمح بإنشاء مستخدم ومنحه صلاحيات الإ بعد الأنصال بالنظام "6ءء ويكون 

الأنصال بالنظام وبأي مستخدم بالصيغة التالية: 

SQL>Connect [user name] OR SQL>conn [uSer name] 
ع لأعطاء صلاحية الأتصال مع باقي الصلاحيات لمستخدم نستخدم الصيغة التالية:‎ 

SQL>Grant connect,resource to [user name] 
وبهذا يتم منح الصلاحية بالعبارة التالية:‎ 
Grant succeeded 
شروط خاصة باسم الجدول:‎ 

8 أن لا يحمل جدول قديم نفس الاسم (بمعنى الا يتكرر اسم الجدول ). 
ك أن لايبدا الأ بحرف من ]A-2[‏ أو[z-ه].‏ 
ك أن لا يحمل رموز ولا فراغات ماعدا الرموز التالية [# $ _ ,] 
8 أن لايزيد عدد الأحرف عن ١‏ حرفاً. 
8 أن لا يكون من الكلمات المحجوزة. 


لغة أوراكل غير حساسة في حالة الأحرف 
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جدول أنواع البيانات 
Char raw‏ 


Varchar , Varchar2 Long raw 


number CLOB 
Date BLOB 
Long BFile 


ثد الوا SQL‏ 
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DDL rag gl 
Create table :رn‎ 


+ + 
Create table table_name الصيغه العامة“‎ 
( 


column_name1 data_type, 
column_name2 data_type, 


متال : جدول الطلاب 
SQL> Create table student‏ 


St_no number(5), 
St_name varchar2(50), 
St_address varchar2(30), 
St_phone number(20) 


) 
عمل إنشlء‏ الفqارس Create index‏ 
الفهرس يصمم في الجدول حتى يجعل عملية الاستعلام أسرع كما يمكن أنشاء أكثر من فهرس نفس الجدول 
ملاهظة: المستخدم لايرى هذه الفهارس إنما هى لتسريع عملية الأستعلام فقط. 
أنواع الفهارس: 
النوع الأول : لايمكن أن تتكرر فيه البيانات. 
النوع الثاني: يمكن تكرار البيانات فيه. 
بناء فهرس من النوع الفريد (الذي لا یتکرر)×٥‏ لہا مuں۹اہلا‏ وصیغتھا : 


CREATE UNIQUE INDEX index_name 
ON table name (column_ name 


بناء فهرس من النوع العادي×ەل"| Simple‏ 


CREATE INDEX index_nam 
ON table_name (column_name) 
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الأمثلة: 
Create index studentindex (1)‏ 
On student (st_name)‏ 
لإنشاء فهرس بترتيب عكسي: 
Create index studentindex‏ 
On student (st _ name Desc)‏ 
لإنشاء فهرس في حقلين في نفس الجدول: 
Create index studentindex‏ 
On student (st_name ,st_address)‏ 


اnرTable Drop‏ 
يقوم هذا الأمر بحذف الجدول بما يحتويه من حقول وقيود 
وبیانات 


DROP TABLE table name 


SQL> Drop table student; 


ما حظا ت : 
حذف قاعدة البيانات يكون كالتالي: 
SQL>drop Database database_name‏ 


حذف فهرس يکون کالتالي: 
SQL>drop index index _ name‏ 


Alter Table jn E 


هي مجموعة من الأوامر التي تقوم تسري بعمليات على هيكل الجدول من حقول وقيود 
كالإضافة والحذف والتعديل. 
أنواع الأمر :Alter Table‏ 
1-Add‏ 
2-Drop‏ 
3-modify‏ 
4-Rename‏ 
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Alter 1aطامل الصيغة العامة‎ 
SQL>AIter table <table_ name> 
(Add / Drop / Modify / Rename) ڊبgنذطalا تيار‎ 
(الحق ول المطوب)‎ 

Add : ا‎ 

SQL>AIter table student add(st_ Gender char(1)); 
SQL>AIter table student add st_ Gender طریقة أخر”‎ 
char(1); 


صلاحطق: . 
الأقواس في حالة أضافه حقل واحد يكون اختياري أما في حالة تعدد الحقول يكون 
إاجباري..... هذا وفي کل اوامر انواع ماطاھ) A6۲‏ 


Drop : انيا‎ 
SQL>AIter table student drop column st_address ; 
ںام بجعلوءءمإللج_)S في قوسين()‎ ٠٣١ يمكن الاستغناء عن كلمة‎ 


Modify: 
SQL>AlIter table student Modify st_no number(10) ; 
Or 
SQL>AIter table student Modify st_no number(2) ; 


ملاحظة: في حالة التعديل الحجم في الرقم إلى الأضغر يشترط أن لا يكون في الجدول بيانات 
راڊ Rename:‏ 


SQL>AIter table student Rename column st_no To S_ number ; 
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المحددات ( القيود) Data Constraint‏ 
هناك مجموعة من المحددات يمكننا استخدامها على الحقول وهي كالتالي: 

يجب إدخال قيمة في الحقل Not Null‏ * 

أن لا تتكرر قيمة الحقل Unique‏ * 

وضع قيمة افتراضية للحقل Default‏ * 

إجراء فحص معين على الحقل Check‏ * 

إنشاء مفتاح رئيسي Primary key‏ * 

إنشاء مفتاح أجنبي Foreign key‏ * 


طر ق إانشاء القيود: 
١‏ -إنشاء المحدد على نفس الحقل "٠[‏ أا "آ] »أي يكتب في نفس السطر تعريف الحقل أو في 
السطر التالي مباشرة. 
-إنشاء جميع المحددات بعد الانتهاء من تعريف الحقول[٥٣‏ أا ut‏ 0] › وهي الأفضل حسب 
رأي الكثيرين . 
ملاحظة. 
الطريقتين تسريان إلى جميع المحددات(القيود) الستة المذكورة › ماعدا المحدد ذو 
القيمة الافتراضية للحقل(]ااه؟ D٠‏ )فينفذ عليه الطريقة الأولى. 
شروط المحدد (القيد): 
-١‏ أن لا يتكرر 
ھان ا یز عن + رقا 
۳- المحدد ذو القيمة الافتراضية للحفل(اu‏ هه 0)فينفذ عليه الطريقة الأولى[٥م‏ اا ۸ا]. 


*المحدد الأول (ااں‌N )Not‏ 


وهو وضع قيد على حقل ما › بحيث لا يكون هذا الحقل ذو قيمة فارغة» أي يجب أن يحتوي على 
قيمة. 


كحقل الطالب واسمه مثلاً يجب أن يحويان على قيمة.. 


تطبيق الطريقة الأولى "٥[‏ ا ]1١‏ في المثال: 


SQL>Create table student 


St_no number(5) Not Null, 
St_name varchar2(50)Not Null, 
St_address varchar2(20) 


) 
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تطبيق الطريقة الثانية ٣٠٥[‏ أا ut‏ 0] في المثال: 


SQL>Create table student 
( 


St_no number(5) , 

St_name varchar2(50), 

St_address varchar2(20), 
Constraint st_no_ch check(st_no is not null), 
Constraint st_ name_ch check(st_name is not null) 


) 


* المحدد الثانی (مuواہ‏ ل) : 
ومعناه ألا تتكرر قيمة هذا الحقل الذي سنضع هذا القيد عليه»فمثلا لو وضعنا هذا القيد على 
حقل رقم الطالب نستنتج من ذلك أننا لا نريد أن يتكرر رقم الطالب. 
Line‏ ہا] للمتال 


SQL>Create table student 


St_no number(5) Unique, 
St_name varchar2(50)Not Null, 
St_address varchar2(20) 


) 


ق الطریقة الثانیة ١٥٣ا‏ †ںص] للمثال :)(Uni‏ 


SQL>Create table student 


St_no number(5) , 

St_name varchar2(50), 

St_address varchar2(20), 
Constraint st_no_un unique(st_no) 


) 
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* المحدد الثالث (†اںج؟م0) : 
ونستفيد منه في وضع قيمة افتراضية لحقل ما › مثلاً عمر الطالب»نضع قيمة افتراضية 
لعمره»وذلك في حالة عدم إدخال المستخدم أي قيمة.. وهو القيد الوحيد الذي يكتب 
بطريقة الأولیى ٥[‏ أا ۸ا]فقط.. 
مثال : 
SQL>Create table student‏ 


( 
St_no number(5) Not Null, 
St_name varchar2(50)Not Null, 
St_age number(2) default 20, 
St_Nation varchar2(20) default 'Yemani', 
St_address varchar2(20) 


) 


* المحدد الرابع )Check)‏ : 
ونستفيد منه عندما نريد أن نفحص قيمة مدخلة لحقل معين يقبل مجموعة قيم محددة . 
حيث يقوم القيد بفحص القيمة المدخلة من بين القيم الموجودة.. 


تطبيق الطريقة الأولی ٣٥[‏ اا ٣ا]‏ للمثال على هذا المحدد (ckمC©):‏ 


SQL>Create table student 


St_no number(5) Not Null, 

St_name varchar2(50)Not Null, 

St_sex char(1) check(St_sex in('m','f')),ركڏ,‎ 

St_age number(2) check(St_age between 19 and 30), 
St_address varchar2(20) 


بيق الطريقة الثانية [٥ہ‏ اا ut‏ ص] للمثال 


( 
St_no number(5) Not Null, 


St_name varchar2(50)Not Null, 
St_sex char(1), 

St_age number(2) 

St_address varchar2(20), 
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Constraint st_sex_ ch check(st_sex in(m','f')), 
Constraint st_ age_ch check(st_ age between 20 and 30) 


): 


وظيفة هذا القيد إعطاء حقل معين من عدة حقول في جدول ما؛ صفة المفتاح الرئيسي 
في هذا الجدول . يحدد بشكل وحيد ومتفرد بحيث يتميز عن غيره.فلا تتكرر قيمته في 
أكثر من حقل واحد ولا يقبل قيم (ااں) أي لا يمكننا أن نترك الحقل فارغاً بدون قيمه. 


SQL>Create table student 


St_no number(5) primary key , 
St_name varchar2(50), 
St_address varchar2(20) 
): 

بق الطريقة الثانیة ٣٥[‏ اا ٤ں‏ 0] للمثال على هذا المحدد 


SQL>Create table student 


St_no number(5) , 
St_name varchar2(50), 
St_address varchar2(20), 
Constraint St_no_pk Primary key(St_no) 
); 


* المحدد اlسادس (forgein key)‏ : 
وظيفة هذا القيد إعطاء حقل معين من عدة حقول في جدول ما.وسمي المفتاح الأجنبي بهذا الاسم لأنه 
لين من الحقول الموجوةة صلا فن الجدول ءإي انه طبار ة ن خفن أو أف تضاف إلى جدول اربطة 


مع جدول آخر. 


ملاحظة: نكون جدولين لبيان المفتاح الأجنبي 
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rable section‏ جدول Mister)‏ )الأب 


SQL>Create table section 
(sec_no number(2) primary key, 
Sec_name varchar2(20) not null 
) 
جدول (|اiج]م0) الابن‎ Table student 


SQL>Create table student 
(st_no number(7) primary key, 
St_name varchar2(30) not null, 
sec_no number(2) 


) 
بیق الطریقۂ الثانیۂ [٥٣اا‏ †ںص0] للمثال 


SQL>Create table student 
(st_no number(7) primary key, 
St_name varchar2(30) not null, 
sec_no number(2), 


الأمر ٥٣4۳٠:‏ 8: أمر للتعديل على أسم الجدول 


SQL> Rename student to student2; : مثال‎ 


ويمكن أن نعدل الجدول من داخل ٥)اA‏ 
SQL> Alter table student Rename to student2‏ 
الامر أمComm‏ : يعمل على عمل التعليق للجدول في حالة نسيان 
وظيفة الجدول أو الحقل المطلوب عمل له التعليق. 
مثال على جدول: 


SQL>comment on table student is ' هنا نكتب التعليٿق‎ ' ; 


يكون التعليق بين علامة تنصيص مفردة 
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مثال على التعليق في حقل: 


; "هنا نكتب lلتعليق‏ ' SQL>comment on Column student.st_no İs‏ 
لإلغاء التعليق في جدول 
SQL>comment on table student is '';‏ 
لإلغاء التعليق في حقل 
SQL>comment on Column student.st_no is ";‏ 
أمر استرجاع جدول بعد الحذفإمهإ0] يعمل [من إصدار و10وما فوق] 


Flashback table 
SQL> Flashback table student to before drop; 
يرجع الجدول وحقوله وبدون القيود‎ 
الاستعلام أو أظهار الجداول المحذوفة اللي عملنا لها مه5‎ * 


SQL> show Recyclebin; 
SQL> purge table student; 

*ويمكن حذف جميع الجداول في ۸اطم‌اعر‌مR‏ 
SQL> purge Recyclebin;‏ 


SQL> drop table student purge; 
أمز لحذف جدول نهائياً.‎ :: 
يحجز أوراكل مساحة ی قاعدة البيانات لسلة المحذوفات هذه‎ : 
. المحذوفات يمكن استعادها إلى القاعدة ويمكن حذفها نهائياً‎ 
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DML rag Li 
يقوم هذا الأمر بإضافة سجل للجدول.‎ 1٣50۲۲ أولا : اأمر هاا‎ 
| INSERT INTO table_name 
VALUES (value1, value2,....) وصيغتها العامة‎ 
INSERT INTO table_name (column1, column2,...) 
VALUES (value1, value2,....) 


الأمظلة: 


SQL>insert into student(st_no ,st_name , 
birth date) 
ENESK(10,'alsaeedi','22-dec-1987’) 


date yi varcharsi varchar2ويأİ‎ char عyi أي حJa من‎ ESE 


يكتب في القيم بين علامة تنصيص مفرده. 


نفس المثال السابق ولكن بطريقة أخرى: 
SQL>insert into student(st_no ,st_name , birth_ date)‏ 
ZHFEK(&st_no , &st_name , & birth_date)‏ 


مثال آخر: 
SQL> INSERT INTO STUDENT (Last_Name, Address)‏ 
(“alsaeedi', sana a')‏ 


وهناك العديد من الطرق لإضافة بيانات ويمكن أضافتها من جدول آخر عن طريق ام امS؟‏ 
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فانيا : الأمر عد لملا: يقوم هذا الأمر بتعديل بيانات عمود كامل أو مجموعة 


من البيانات في العمود بحسب شرط معين. 


: الصيغة العامة:‎ 
UPDATE table_name 


SET column_name = new_value 


WHERE column_name = some_value 


الا منلة: 


SQL>update student set st _ age=20; 


SQL>update student set st age=20 


Where section_no=2; 


SQL>update student 

set st_city='albyda a" 

where dept_name='computer sciences’; 
SQL> update student 

SET Address = 'alrabaad street', City = 'sana a' 
WHERE Last _ Name = 'alsaeedi' 


ملاحظات - 

@ التعديل على بيانات الجدول يتم على مستوى العمود 

إن لم توجد جملة شرط في التعديل فأنه سوف يتم تعديل جميع 
اا ال 
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فا لا : الأمر ١٠٥ا٥0:‏ يقوم هذا الأمر بحذف بيانات الجدول أما جميع البيانات 
للسجلات أو مجموعة سجلات أو سجل معين بشرط معين. 
الصيغة العامة: . کت ح تيت 
DELETE from table_name‏ | 
WHERE column_name = some value‏ 


SQL> Delete from student; 


SQL> Delete from student 


_ Where st _ name='alsaeedi'; 
__ حذف مع الشرط‎ 


SQL> Delete from student 
Where st_ age>=18; 
حذف مع الشرط‎ 
ملاحظات-‎ 
الحذف في الجدول للبيانات يتم على مستوى السجل كامل‎ L1 
إن لم يحتوي مر الحذف على جملة شرط فسوف يتم حذف بيانات جميع‎ 
السجلات.‎ 
-عندما نملك جدولين مثلا(الطلاب والأقسام) فإننا لا نستطيع حذف بيانات وخاصة إذا كانت هناك‎ 
بين الجدولين علاقة ممه ه† ومجم فمثلا في الجدولين الطلاب والأقسام فإننا لا نستطيع حذف‎ 
بيانات الأقسام مباشرة وهناك سجلات في الطلاب مرتبطة بها إلا بأحد الطرق التالية:‎ 


SQL>delete student ; حذف البيانات في الطلاب‎ - ١ 
SQL>delete section ; حذف البيانات في الأقسام‎ - 
On delete cascadم عند إنشاء قيد المفتاح الثانوي نضيف‎ 


Constraint FK foreign key(sec_no) references section(sec_no) 
on delete cascade); 
SQL>delete section; تم نحدف بيانات‎ - 
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رابعا : اهر ٥و١٥06[:‏ أمر يقوم بنسخ سجلات لجدول أو منظور أو استعلام إلى 
داخل جدول جديد وفي حالة أن يكون السجل موجود يقوم بعملية التعديل وان لم يوجد 
السجل فيقوم بعملية إضافة للسجل. 


Merge into table_name alias الصيغة العامة:‎ 
Using (table /view/sub-Query) alias 
On (join condition) 


When matched then 
Update set 

Col 1 = col val, 

Col 2 = col_val 


When not matched then 
Insert (column _ list) 
Values (column_values) ; 


SQL> Merge into student S 
using old-student O 

On (s.s_ NO=0O. s_No) 

When matched then 
update set 

S.S_No =0.s NO, 
S.S_name =0.sSs_ name , 
s.s_Age =o0.s_ Age, 

S . sec_No =0. sec_ No 

when not matched then 
insert values (O0 .s_no,o.s_name,o.s_Age,o.sec_no); 
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قبل جمل امع نذكر الأوامر المتعلقة التحكم بحركة البيانات 


؛>- القسم المسئول عن اللغة التحكم الحركة البيانات( 1 )۲٤٣‏ 

Transaction control language 

ww ااm الأمر‎ 
SQL>Commit ; 


SQL>RolIlback 


هذا الأمر يقوم بتثبيت عمل أوامر |5 على Data base‏ 
[to savepoint] ;‏ 


يقوم هذا الأمر بالتراجع عن جميع أوامر D11‏ التي تم تنفيذها 

سابقاً حتی آخر ا0۳۸٥‏ 
أsavepoin><‏ 1 SQ‏ وضع إشارة محددة بين مجموعة أوامر _00 يتم تنفيذ 
<savepoint name>‏ 


ها ليتم استخدامها في 
أمر )عه طااه۴ لرجوع عن جميع أوامر 001 التي نفذت وحتى آخر أمر بعد 
. oiniم6ave‏ المستخدمه. 
9 


SQL>savepoint huzam; 
SQL>RoIIback to savepoint huzam; 


أوامر D11‏ لا يتم تثبيتها على قاعدة البيانات إلا باستخدام الأمر "0© بعد تنفيذها 


E E 
عرض حقول الجدول‎ Desc<table name> 
ظهور محرر النصوص‎ Ed 
إظهار محتويات ملف‎ Get filename 
تنفيذ أوامر موجودة في ملف‎ Start filename 
تفیذ آخر أمر‎ Run ORR OR | 
تنفيذ ملف تنفيذي‎ Host txt 
Spool on 
Spool off 
S۵1 ٣اںs للخروج من‎ Exit 
للارتباط بالمستخدم‎ Conn username 
فك الارتباط‎ Disc 


لكتابة مجموعة أوامر وناتجها في ملف 
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SELECT column_name(s) 
FROM table name 


SELECT DISTINCT column_name(s) 
FROM table naneرlرSت‎ jودب استعلام‎ 
SELECT column FROM table 
WHERE column operator value 
استعلام الشرط‎ 
SELECT column FROM table 
WHERE column LIKE pattern 


الأمثلة- 


جميع البيانات الموجودة في جدول الطلاب ۲077 * S|‏ <اSQ‏ 
student;‏ 


- الاستعلام عن رقم القسم واسمه من جدول الأقسام. (الصيغة الأولى) 
SQL> Select sec_ no ,sec_ name‏ 
From section;‏ 


- الاستعلام عن الاسم الأخير والاسم الأول من جدول بيانات الطلاب. (لصيغة الأولى) 
SQL> SELECT LastName,FirstName FROM student;‏ 


-اختيار رقم الطالب من جدول الطلاب بدون تكرار. (الصيغة الثانية) 
SQL> SELECT DISTINCT st_ no FROM student;‏ 


-اختيار أرقام الطالب وأسمائهم من جدول الطلاب بدون تكرار. (الصيغة 


الثانية) 
SQL> SELECT DISTINCT st_no,st_name FROM‏ 
student;‏ 


alsaeedi 999@hotmail.com 


أعداد/ عبدالرحمن جمال محسن السعيدى 


PDF created with pdfFactory Pro trial version www.pdffactory.com 


الشروط Where condition‏ 
وهو الشرط الذي من خلاله سيحدد السجلات الذي سيتم عرضها من خلال 
جملة الاستعلام 


والشرط يحتوي على عدة عمليات هي : 
عمليات المقارنة المعروفة comparison operators‏ -)1( 
فاق 


I= OR ^=‏ 9 تساوي 
عملية المساواة 
أصغر من 
اکبر من 
اصغر من أو يساوي 
اكبر من أو يساوي 


(2)- Logical operators عمليات المنطقية الثلاث‎ 
[ AND , OR, NOT] 


الأمثلة: 
SQL> select st_no ,st_name‏ 
From student‏ 
Where sec no = 2 and st_mark > 50 ;‏ 


SQL> select st_no ,st_name 

From student 

Where sec_no = 2 and (st_mark < 50 OR st_Age 
> 20( 


(2)- SQL operators عمليات إضافية لزيادة التحكم‎ 
[IN , Between , is null , like] 


SQL> select st_no ,st_name 
From student 
Where sec_no in (1 , 2) 
And st_mark between 60 and 90 
And st_Age is null ; 
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SQL> select st_no ,st_name 
From student 
Where st_ name like '%a' Or st_name like 'a%' ; 


Order by clouse 


لعرض البيانات بترتيب معين نستخدم لط ٥۲‏ ل۲٠‏ وبجانبها الحقول التي 
سيتم الترتيب على أساسها أو عن طريق رقم ترتيب الحقل وبعدها أحدى 
الكلمات التالية: 
٥‏ ترتيب تصاعدي أو ترکها فارغ 
6٥‏ :!: ترتیب تنازلي 
الأمثلة٠‏ 
SQL> select st_no ,st_name‏ 
From student‏ 
Order by st_no Asc ;‏ 


SQL> select st_no ,st_name 
From student 
Where st Age > 20 
Order by st_no , sec_no Desc ; 


المتغير البديل substitution variable‏ 
يسمح للمستخدم بإدخال قيمة الحقل من لوحة المفاتيح 


SQL> select st_no ,st_name 
From student 
Where sec no = &section_no ; 
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وأخيرا أتمنى أن تكونوا قد استفدتم من هذا الجزء بالشكل المناسب. 
وفي النهاية : 

أحب إن أقول أن عالم مو2 طهاه عالم واسع كالمحيط لذلك 

ممكن أن يكون هناك أمور كثيرة لا أعرفها. 


أتمنى من الله أن أكون قد وفقت في عملي هذا وأتمنى من الله أن 
ينال هذا الكتاب إعجابكم ورضاكم وفي الأخير أعتذر منكم على 
التقصيرفي بعض الأشياء. 

وترقبوا الجزء الثاني من كتاب (الكامل في الأوراكل) 


4/۸ 0م 
۹/ذي القعدة/۹١٠٤١‏ 
a A1۹1۷‏ 
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